:root{
  --primary:#663399;
  --error:#ee4866;
  --success:#1ba784;
  --default:#999;
}

#app{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background-color: #663399;
}


.button{
  width: 200px;
  height: 50px;
  color: #663399;
  background-color: #fff;
  border-radius: 5px;
  text-align: center;
  line-height: 50px;
  cursor: pointer;
}

.button:active{
  transform: scale(.98);
}

.notice{
  position: absolute;
  right: 10px;
  bottom: 0;
  width: 250px;
  height: 50px;
  background-color: #fff;
  text-align: center;
  line-height: 50px;
  border-radius: 5px;
  /* transition: transform .3s linear; */
  animation:translationY .1s ease-in-out ;
}

@keyframes translationY{
  0%{
    transform: translateY(0);
  }
  100%{
    transform: translateY(auto);
  }
}

.primary{
  color: var(--primary);
}
.error{
  color: var(--error);
}
.success{
  color: var(--success);
}
.default{
  color: var(--default);
}
